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^ (54) Title: METHOD AND APPARATUS FOR CONTOOLUNG AN EXTENSIBLB COMPUTING SYSTEM 
O 

^ (57) Abstract: Methods and apparatus providing, controlling and managing a dynamically sized, highly scalable and available server 
farm are disclosed. A "Virtual Server Farm (VSF) is created out of a wide scale computing fabric ("Computing Grid") which is 
^ physically constructed once and then lexically divided up into VSFs for various organizations on demand. Each organization retains 
independent administrative control of a VSF. A VSF is dynamically fiiewalled within the Computing Grid. Allocation and control 
of the elements in the VSF is performed by a control plane connected to all computing, networidng. and storage elements in the 
Q computing grid through special control ports. The interna] topology of each VSF is under control of the control plane. No physical 
rewiring is necessary in order to construct VSFs in many dififerent configurations, inchiding single-tier Web server or multi-tier. 
Web-server, application server, database server configurations. 
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METHOD AND APPARATUS FOR CONTROLLING AN 

EXTENSIBLE COMPUTING SYSTEM 

FIELD OF THE INVENTION 

The present invention relates generally to data processing. The invmtion relates 
iDore specifically to a method and apparatus for controlling a computing grid. 

BACKGROUND OF THE INVENTION 

Builders of Web sites and other con^uter systems today are faced with many 
challenging systems planning issues. These issues include opacity planning, site 
availability and site security. Accomplishing these objectives requires finding and hiring 
trained personnel enable of engineering and operating a site» which may be potentially 
large and complicated. This has provm to be difGcult for many organizations because 
designing, constructing and op^ting large sites is often outside their core business. 

One approach has been to host an enteiprise Web site at a third party site, co- 
located with other Web sites of other enterprises. Such outsourcing facilities are cmtentiy 
available firom companies such as Exodus, AboveNet, GlobalCenter, etc. These facilities 
provide physical space and redundant network and power facilities shared by multiple 
customers. 

Although outsourcing web site hosting greatiy reduces the task of establishing and 
maintaining a web site, it does not reheve a company of all of the problems associated 
with maintaining a web site. Companies must still perform many tasks relating to their 
computing infi^tructure in the course of building, operating and growing their facilities. 
Information technology managers of the enterprises hosted at such facilities remain 
responsible for manually selecting, installing, configuring, and ma i n ta ini n g their own 
computing equipment at the facilities. The managers must still confix)nt difficult issues 
such as resource planning and handling peak capacity. Specifically, managers must 
estimate resource demands and request resources from the outsourcing company to 
handle the demands. Many managers ensure sufficient cq}acity by requesting 
substantially more resources than are needed to provide a cushion against unexpected 
peak demands. Unfortunately, this often results in significant amounts of unused capacity 
that increases companies' overhead for hosting their web sites. 

Even when outsourcing companies also provide conqjlete con:q)uting faciUties 
including servers, software and power facilities, the facilities are no easier to scale, and 
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grow for the outsourcing company, because grow& involves the same manual and error- 
prone administrative steps. Lx addition, problems remain with capacity planning for 
unexpected peak demand. Iti this situation, the outsourcing companies o^n maiatain 
significant amounts of unused capacity. 

Further, Web sites managed by outsourcing companies often have different 
requirements. For example, some companies may require the ability to independently 
administer and control their Wefo sites. Other companies may require a particular type or 
level of secinity that isolates their Web sites from all other sites ttiat are co-located at an 
outsourcing company. As another example, some companies may require a secure 
coimection to an enterprise Intranet located elsewhere. 

Also, various Web sites differ in internal topology. Some sites simply comprise a 
row of Web servers that are load balanced by a Web load balancer. Suitable load 
balancers are Local Director from Cisco Systems, Inc., BiglP from FSLabs, Web Director 
from Alteon, etc. Other sites may be constructed in a multi-tier fashion, whereby a row 
of Web servers handle Hypertext Transfer Protocol (HTTP) requests, but the bulk of the 
application logic is implemaited in separate application servers. These application 
servers in turn may need to be connected back to a tier of database servers. 

Some of these different configuration scenarios are shown in FIG. 1 A, FIG. IB, 
and FIG. IC. FIG. 1 A is a block diagram of a simple Web site, comprising a single 
computing element or machine 100 that includes a CPU 102 and disk 104. Machine 100 
is coupled to the global, packet-switched data network known as the Intmiet 106, or to 
another network. Machine 1 00 may be housed in a co-location service of the type 
described above. 

FIG. IB is a block diagram of a 1-tier Web server farm 110 comprisiog a plurality 
of Web servers WSA, WSB, WSC. Each of the Web servers is coupled to a load- 
balancer 1 12 that is coupled to Memet 106. The load balancer divides the traffic 
between the servCTS to maintain a balanced processing load on each server. Load 
balancer 1 12 may also include or may be coupled to a firewall for protecting the Wd) 
servers fi-om unauthorized trafBc. 

FIG. IC shows a 3-tier saver farm 120 comprising a tier of Web serves Wl, W2, 
etc., a tier of applic^on servers Al, A2, etc., and a tier of database servers Dl, D2, etc. 
ITie Web servers are provided for handling HTTP requests. The ^plication servers 
execute the bulk of the application logic. The database servers execute database 
management system (DBMS) software. 
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Given tte diversity in topology of the kiiids of Web sites that need to be 
constructed and the varying requir^ents of the corresponding companies^ it niay appear 
that the only way to construct large-scale Web sites is to physically custom build each 
site. Indeed^ Ihis is the conventional approacL Many organizations are separately 
struggling with the same issues, and custom building each Web site from scratch. This is 
inefficient and involves a significant amount of diq[)licate woric at dififerrat enterprises. 

Still ano&er problem with tiie conventional approach is resource and edacity 
plannmg. A Web site may receive vastly different levels of traffic on dijBEarent days or at 
different hours within each day. At peak traffic tunes, the Web site hardware or software 
may be unable to respond to requests in a reasonable time because it is overloaded. At 
other times, the Web site hardware or software may have excess edacity and be 
underutilized. In the conventional approach, finding a balance between having sufficient 
hardware and software to handle peak traffic, without incurring excessive costs or having 
over-^acity, is a difficult problem. Many Web sites never find the right balance and 
chronically suffer from mider-capacity or excess capacity. 

Yet another problem is failure mduced by human error. A great potential hazard 
present in the current approach of using manually constmcted server farms is tiiat human 
error in configuring a new servier into a live server farm can cause the server farm to 
malfimction, possibly resulting in loss of service to users of that Web site. 

Based on the foregoing, there is a clear need in this field for improved methods 
and ^jparatuses for providing a computing system that is instantly and easily extensible 
on demand without requiring custom constructioiL 

There is also a need for a computing system that supports creation of multiple 
segregated processing nodes, each of which can be expanded or collapsed as needed to 
account for changes in traffic throughput 

There is a further need for a method and apparatus for controlling such an 
extensible conq)uting system and its constituent segregated processing nodes. Other 
needs will become apparent from the disclosure provided herein. 

SXJMMARY OF THE INVENTION 

According to one aspect of the invention, the foregoing needs, and other needs 
and that will become parent team the following description, are achieved by a method 
and ^paratus for controlling and managing a highly scalable, highly available and secure 
data processing sites, based on a wide scale computing &bric ("computing grid"). The 
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computing grid is physically constructed once, and then logically divided \xp for various 
organizations on demand. The conq>utmg grid comprises a large plurality of computing 
elements that are coupled to one or more VLAN switches and to one or more storage area 
netwoik (SAN) switches. A plurality of storage devices are coupled to the SAN switches 
and may be selectively coupled to one or more of the computing elements through 
appropriate switching logic and commands. One port of the VLAN switch is coupled to 
an external network, such as the Xntemet A supervisory mechanism, layer, machine or 
process is coupled to the VLAN switches and SAN switches. 

Initially, all storage devices and computing elements are assigned to Idle Pools. 
Under program control, the supervisory mechanism dynamically configures the VLAN 
switches and SAN switches to couple their ports to one or more computing elements and 
storage devices. As a result, such elements and devices are logically removed from the 
Idle Pools and become part of one or more virtual server farms (VSFs) or instant data 
centers (IDCs). Each VSF computing element is pointed to or otherwise associated with 
a storage device that contains a boot image usable by the computing element for bootstrap 
operation and production execution. 

According to one aspect of the invention, the supervisory layer is a control plane 
comprised of a control mechanism hierarchy that includes one or more master control 
process mechanisms communicatively coupled to one or more slave control process 
mechanisms. The one or more master control process mechanisms allocate and de- 
allocate slave control process mechanisms based \tpon slave control process mechanism 
loading. The one or more master control process mechanisms instruct the slave control 
process mechanisms to estabUsh IDCs by selecting subsets of processing and storage 
resources. The one or more master control process mechanisms perform periodic health 
checks on the slave control process mechanisms. Non-responsive or failed slave control 
mechanisms are restarted. Additional slave control mechanisms are initiated to replace 
slave control mechanisms that cannot be restarted. The slave control mechanisms 
perform periodic health checks on the master control mechanisms. When a master slave 
control process mechanism has failed, a slave control process mechanism is elected to be 
a new master control process mechanism to replace the feiled master control process 
mechanism. 

Physically constructing the conq>uting grid once, and securely and dynamically 
allocating portions of the conq>uting grid to various organizations on d^iand achieve 
economies of scale fliat are difficult to achieve when seating a custom build of ^ch site. 
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BMEF DESCRIPTION OF TEffl DRAWINGS 

The present invention is illustrated by way of example, and not by way of 
limitation, in the figures of the accompanying drawings and in which like reference 
numerals refer to similar elem^ts and in which: 

FIG. lA is a block diagram of a simple Web site having a single computing 
el^ent topology. 

FIG. IB is a block diagram of a one-tier Web server fann. 

FIG. IC is a block diagram of a three-tier Web server farm. 

FIG. 2 is a block diagram of one configuration of an extensible conq)uting system 
200 that includes a local computing grid. 

FIG. 3 is a block diagram of an exemplary virtual server fiam featuring a SAN 

Zone. 

FIG. 4A, FIG. 4B, FIG, 4C, and FIG. 4D are block diagrams showing successive 
steps involved in adding a computing element and removing element &om a virtual server 
farm. 

FIG. 5 is a block diagram of an embodiment of a virtual server farm system> 
computing grid, and supervisory mechanism. 

FIG. 6 is a block diagram of logical connections of a virtual server farm. 

FIG. 7 is a block diagram of logical connections of a virtual server farm, 

FIG. 8 is a block diagram of logical connections of a virtual server f ami. 

FIG. 9 is a block diagram of a logical relationship between a control plane and a 
dataplane. 

FIG. 10 is a state diagram of a mastCT control election process. 

FIG. 1 1 is a state diagram for a slave control process. 

FIG. 12 is a state diagram for a master control process. 

FIG. 13 is a block diagram of a central control processor and multiple control 
planes and computing grids. 

FIG. 14 is a block diagram of an architecture for implementing portions of a 
control plane and a computing grid. 

FIG. 1 5 is a block diagram of a system with a computing grid tiiat is protected by 
afirewalL 

HG. 1 6 is a block diagram of an architecture for connecting a control plane to a 
computing grid. 
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FIG. 17 is a block diagram of an airangenaeat for enforcing tight binding between 
VLAN tags and IP addresses. 

FIG. 1 8 is a block diagram of a plurality of VSFs extended over WAN 
connections. 

FIG. 19 is a block diagram of a computer system with which an embodiment may 
be implemented. 

DETAILED DESCRIPTION OF THE INVENTION 

In the following description, for the purposes of explanation, numerous specific 
details are set fortli in order to provide a thorough understanding of the present invention. 
It will be apparent, however, to one skilled in the art that the present invention may be 
practiced without these specific details. In other instances, well-known structures and 
devices are shown in block diagram fomi in order to avoid unnecessarily obscuring the 
present invention. 

VIRTUAL SERVER FARM (VSF) 

According to one embodiment, a wide scale computing fabric ("computing grid") 
is provided. The computing grid may be physically constructed once, and then logically 
partitioned on demand. A part of the computing grid is allocated to each of a plurality of 
enterprises or organizations. Each organization's logical portion of tiie computing grid is 
referred to as a Virtual Server Farm (VSF). Each organization retains independent 
administrative control of its VSF. Each VSF can change dynamically in trams of number 
of CPUs, storage capacity and disk and network bandwidth based on real-time demands 
placed on the server farm or other factors. Each VSF is secure fiom every othbr 
organization's VSF, even though they are all logically created out of the same physical 
confuting grid. A VSF can be connected back to an Intranet using either a private leased 
line or a Virtual Private Network (VPN), without exposing the Intranet to other 
organizations' VSFs. 

An organization can access only the data and computing elements in the portion 
of the computing grid allocated to it, that is, in its VSF, even though it may exerdse fiill 
(e.g. sq)er-user or root) administrative access to these coiEq>uters and can observe all 
trafBc on Local Area Networks (LANs) to vAich these conq)uters are connected. 
According to one ^bodiment, this is acconq>lished using a dynamic firewalling scheme, 
where flie security perimeter of the VSF expands and shrinks dynamically. Each VSF can 

-6' 
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be used to host the content and ^plications of an organization that may be accessed via 
the Ihtemety Intranet or Extranet 

Configuration and control of the computing elements and their associated 
networking and storage elements is performed by a supervisory mechanism that is not 
directly accessible through any of the computing elem^ts in the computing grid. For 
convenience, in this document the supervisory mechanism is referred to genwally as a 
control plane and may comprise one or more processors or a networic of processors. The 
supervisory mechanism may comprise a Siq)ervisor, Controller, etc. Other approaches 
may be used, as described herein. 

The control plane is implemented on a completely independent set of computing 
elements assigned for supervisory purposes, such as one or more servers that maybe 
intercoimected in a network or by other means. The control plane performs control 
actions on tiie computing, networking and storage elements of the computing grid through 
special control ports or inter&ces of the networking and storage elements in the grid. The 
control plane provides a physical interface to switching elranents of the system, monitors 
loads of computing elements in the system, and provides administrative and management 
functions using a graphical user interface or other suitable user interface. 

Computers used to implement the control plane are logically invisible to 
computers in the computing grid (and therefore in any specific VSF) arid cannot be 
attacked or subverted in any way via elements in the computing grid or from external 
computers. Only the control plane has physical connections to the control ports on 
devices in the coniputing grid, which controls membership in a particular VSF. The 
devices in the computing can be configured only through these special control ports, and 
therefore computing elements in the computing grid are unable to change their security 
perimeter or access storage or computing devices which they are not authorized to do. 

Thus, a VSF allov/s organizations to work with computing facihties that ^pear to 
comprise a private server farm, dynamically created out of a large-scale shared computing 
infrastructure, namely the coii^uting grid. A control plane coiipled with the computing 
architecture described herein provides a private server feim whose privacy and iategjity is 
protected through access control mechanisms implemented in the hardware of the devices 
of the computing grid. 

The control plane controls the internal topology of each VSF. The control plane 
can take the basic interconnection of computers, network switches and storage network 
switches described herein and use them to create a variety of server farm configurations. 
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These include but are not limited to, single-tier Web server farms front-ended by a load 
balancer, as well as multi-tier configurations, where a Web server talks to an ^plication 
server, which in tmn talks to a database server. A variety of load balancing, multi-tiering 
and fiiewalling configmBtions are possible. 

THE COMPUTING GRID 

The conq)uting grid may exist in a single location or may be distributed over a 
wide area First tibis docmnent describes the computing grid in the context of a single - 
. building-sized netwoik, composed purely of local area technologies. Then the document 
desCTbes the case where the computing grid is distributed over a wide area network 
(WAN). 

FIG. 2 is a block diagram of one configuration of an extensible computing system 
200 that includes a local computing grid 208. In this document "extensible" generally 
means that the system is flexible and scalable, having the c^ability to provide increased 
or decreased computing power to a particular enterprise or user upon demand. The local 
computing grid 208 is composed of a large number of computing elements CPUl, CPU2, 
, . . CPUn. In an exeng>lary embodiment, there may be 10,000 computing elements, or 
more. These computing elements do not contain or store any long-lived per-element state 
information, and therefore may be configured without persistent or non-volatile storage 
such as a local disk. Instead, all long lived state information is stored separate from the 
computing elanents, on disks DISKl, DISK2, . . . DISKn that are coupled to the 
computing elements via a Storage Area Network (SAN) comprising one or more SAN 
Switches 202. Examples of suitable SAN switches are commercially available from 
Brocade and Excel. 

All of the.computing elements are iaterconnected to each other throu^ one or 
more VLAN switches 204 which can be divided up into Virtual LANs (VLANs). The 
VLAN switches 204 are coupled to tiie Internet 106. In general a computing elemait 
contains one or two network interfaces connected to the VLAN switch. For the sake of 
simplicity, in FIG. 2 all nodes are shown with two network interfaces^ although some may 
have less or more network interfaces. Many commercial vendors now provide switches 
supporting VLAN fimctionahty. For example, suitable VLAN switches are commercially 
available firom Cisco Systems, hic. and Xtreme Networks. Similarly th^e are a large 
nmnber of commercially available products to construct SANs, including Fibre Cliannel 
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switches, SCSI-to-Fibre-Ghannel bridging devices, and Network Attached Storage (NAS) 
devices. 

Control plane 206 is coiqpled by a SAN Control pafh, CPU Control path, and 
VIJU^ Control path to SAN switches 202, CPUs CPUl, 
Switches 204, respectively. 

Each VSF is conxposed of a set of VLANs, a set of computing elements tiiat are 
attached to the VLANs, and a subset of the storage available on the SAN that is coiq)led 
to the set of computing elements. The subset of the storage available on &e SAN is 
referred to as a SAN Zone and is protected by the SAN hardware from access from 
computing elements that are part of other SAN zones. Preferably, VLANs that provide 
non-forgeable port identifiers are used to prevent one customer or end user from 
obtaining access to VSF resources of another customer or end user. 

FIG. 3 is a block diagram of an exenaplaiy virtual sender farm featuring a SAN 
Zone. A plurality of Web servers WSl, WS2, etc., are coi5)led by a first VLAN 
(VLANl) to a load balancer (LB)/firewall 302. A second VLAN (VLAN2) couples the 
iitemet 106 to the load balancer (LB)/firewall 302. Badi of the Wd> servers may be 
selected from among CPUl, CPU2, etc., using mechanisms described fur&er hoDein. The 
Web s^ers are coupled to a SAN Zone 304, which is coupled to one or more storage 
devices 306a, 306b. 

At any given point in time, a computing element in the confuting grid, such as 
CPUl of FIG. 2, is only connected to the set of VLANs and the SAN zone(s) associated 
with a single VSF. A VSF typicaUy is not shared among different organizations. The 
subset of storage on the SAN that belongs to a single SAN zone, and the set of VLANs 
associated with it and the computing elements on these VLANs define a VSF. 

By controlling the membership of a VLAN and the membership of a SAN zone, 
control plane enforces a logical partitiomng of the computing grid into multiple VSFs. 
Members of one VSF cannot access the computing or storage resources of anotha: VSF. 
Such access restrictions are enforced at the hardware level by the VLAN switohes, and by 
port-level access control mechanisms (e.g., zoning) of SAN hardware such as Fibre 
Chaimel switches and edge devices such as SCSI to Fibre Chaimel bridgmg hardware. 
Conoputing elemmts that form part of the computing grid are not physically connected to 
the control ports or interfaces of the VLAN switohes and the SAN switches, and therefore 
cannot control the membership of the VLANs or SAN zones. Accordingly, the 
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computing elemeats of the computing grid camiot access computing elements not located 
in tiie VSF in v/idch they are contained 

Only flie computing elements that run the control plane are physically connected 
to the control ports or mterface of the devices in the grid. Devices in the computing grid 
(computers, SAN switches and VLAN switches) can only be configured through such 
control ports or interfaces. This provides a simple yet highly secure means of aiforcing 
the dynamic partitioning of the computing grid into multiple VSFs. 

Each computing element in a VSF is replaceable by any other computing element 
The number of computing elements, VLANs and SAN zones associated with a given VSF 
may change over time under control of the Control plane. 

In one embodiment, the computing grid includes an Idle Pool that comprises large 
number of computing elements that are kept in reserve. Computing elements from the 
Idle Pool may be assigned to a particular VSF for reasons such as increasing the CPU or 
memory edacity available to that VSF, or to deal with failures of a particular computing 
element in a VSF. When the computing elements are configured as Web servers, the Idle 
Pool serves as a large "shock absorber*' for varying or **bursty" Web traffic loads and 
related peak processing loads. 

The Idle Pool is shared between many different organizations, and therefore it 
provides economies of scale, since no single organization has to pay for the entire cost of 
the Idle Pool. Different organizations can obtain computing elements fi^om the Idle Pool 
at different times in the day, as needed, thereby enabling each VSF to grow when 
required and shrink when traffic falls down to normal. If many different organizations 
continue to peak at the same time and thereby potentially exhaust the capacity of the Idle 
Pool, the Idle Pool can be increased by adding more CPUs and storage elements to it 
(scalability). The capacity of the Idle Pool is engineered so as to greatly reduce the 
probabiUty that, in steady state, a particular VSF may not be able to obtain an additional 
computing element &om the Idle Pool when it needs to. 

FIG. 4A, FIG. 4B, FIG. 4C, and FIG. 4D are block diagrams showmg successive 
steps involved in moving a computing element in and out of the Idle Pool. Ref(srring first 
to FIG. 4A, assume that the control plane has logically coimected elmnents of flie 
computing grid nito first and second VSFs labeled VSFl, VSF2. Idle Pool 400 comprises 
a pluraKty of CPUs 402, one of which is labeled CPUX. hi FIGi 4B, VSFl has developed 
a need for an additional conq)uting element Accordingly, the control plane moves 
CPUX from Idle Pool 400 to VSFl, as indicated bypath 404. 
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Ja FIG. 4C, VSFl no longer needs CPUX, and therefore the control plane moveis 
CPUX out of VSFl and back into the Idle Pool 400. In FIG. .4D, VSF2 has developed a 
need for an additional computing element Accordingly, the control plane moves CPUX 
fiom the Idle Pool 400 to VSF2. Thus, over the course of time, as trafl&c conditions 
change, a single computing element may belong to the Idle Pool (FIG. 4A), then be 
assigned to a particular VSF (FIG. 4B), then be placed back in the Idle Pool (FIG. 4C), 
and then belong to another VSF (FIG. 4D). 

At each one of these stages, the control plane configures the LAN switches and 
SAN switches associated with that computing element to be part of the VlANs and SAN 
zones associated with a particular VSF (or the Idle Pool). According to one embodiment, 
in between each transition, the computing element is powered down or rebooted. When 
the computing element is powered back up, the computing element views a dififereat 
portion of storage zone on the SAN. In particular, the computing element views a portion 
of storage zone on the SAN that includes a bootable image of an operating system (e.g., 
Linux, NT, Solaris, etc.). The storage zone also includes a data portion that is specific to 
each orgianization (e.g., files associated with a Web server, database partitions, etc.). The 
computing element is also part of another VLAN which is part of the VLAN set of 
another VSF, so it can access CPUs, SAN storage devices and NAS devices associated 
with the VLANs of the VSF into which it has been transitioned. 

In a preferred embodiment, the storage zones include a plurality of pre-defined 
logical blueprints that are associated with roles that may be assumed by the coirputing 
elements. Initially, no computing client is dedicated to any particular role or task such 
as Web server, application server, database server, etc. The role of the computing 
element is acquired fiom one of a plurality of pre-defined, stored blueprints, each of 
^ch defines a boot image for the coinputing clients that are associated with that role. 
The blueprints may be stored in the form of a file, a database table, or any otii^ storage 
format that can associate a boot image location witii a role. 

Thus, the movements of CPUX m FIG. 4A, FIG. 4B, FIG. 4C, FIG. 4D are 
logical, not physical, and are acconqjlished by re-configuring VLAN switches and SAN 
Zones under control ofThe control plane. Further, each conq)Uting element hi the 
computing grid initially is essentially fimgible, and assumes a specific processing role 
only after it is connected in a virtual server farm and loads software fcom aboot image. 
No conq)uting element is dedicated to any particular role or task such as Web server, 
Implication server, database server, etc. The role of the computing el^rat is acquired 
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fiom one of a plurality of pre-defined, stored blueprints, each of which is assodated with 
a role, each of which defines a boot image for the computing elements tiiat are associated 
with that role. 

Smce there is no long-lived state information stored in any given computing 
element (such as a local disk), nodes are easily moved between diJSerent VSFs, and can 
run completely different OS and ^plication software. This also makes each conoputing 
element highly replaceable, in case of planned or unplanned downtime. 

A particular computing element may perform different roles as it is brought into 
and out of various VSFs, For example, a computing element may act as a Web server in 
one VSF, and when it is brought into a different VSF, it may be a database server, a Web 
load balancer, a Firewall, etc. It may also successively boot and run different operating 
systems such as Linux, NT or Solaris in different VSFs. Thus, each computing element 
in the computing grid is fungible, and has no static role assigned to it Accordingly, tibie 
entire reserve capacity of the computing grid can be used to provide any of the savices 
required by any VSF. This provides a hi^ degree of availability and reliability to the 
services provided by a single VSF, because each server performing a particular service 
has potentially thousands of back-up servers able to provide the same service. 

Further, the large reserve capacity of the computing grid can provide both 
dynamic load balancing properties, as well as high processor availability. This capabiUty 
is enabled by the unique combination of diskless conaputing elemrats interconnected via 
VLANs, and connected to a configurable zone of storage devices via a SAN, all 
controlled in real-time by the control plane. Every computing element can act in the role 
of any required server in any VSF, and can coimect to any logical partition of any disk in 
the SAN. When the grid requires more con:q)uting power or disk capacity, conq)uting 
elements or disk storage is manually added to the idle pool, which may decrease over 
time as more organizations are provided VSF services. No manual intervention is 
required in ordo- to increase the number of CPUs, network and disk bandwidfli and 
storage available to a VSF. All such resources are allocated on d^and from CPU, 
network and disk resources available in the Idle Pool by tibie control plane. 

A particular VSF is not subjected to manual reconfiguration. Only the computing 
elemmts in the idle pool are manually configured into the computing grid. As a result, a 
great potential hazard present in current manually constmcted server £ains is removed. 
The possibility fliat human error in configuring a new server into a live sj^er farm can 
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cause the server farm to malfunction, possibly resulting in loss of service to users of that • 
Web site, is virtually eliminated. 

The control plane also rq)licates data stored in SAN attached storage devices, so 
ttiat &ilure of any particular storage elemmt does not cause a loss of service to any part 
of ttie system. By decoupling long-lived storage from computing devices using SANs, 
and by providing redundant storage and computing elements, where any conq>utii^ 
element can be attached to any storage partition, a high degree of availability is achieved. 

A DETAILED EXAMPLE OF ESTABLISHING A VIRTUAL SERVER FARM, 
ADDING A PROCESSOR TO IT, AND REMOVING A PROCESSOR FROM IT 

FIG. 5 is a block diagram of a computing grid and control plane mechanism 
according to an embodiment. With reference to FIG. 5, the following describes tiie 
detailed steps that may be used to create a VSF, add nodes td it and delete nodes from it 

FIG. 5 depicts computing elements 502, comprising corcputers A flirough G, 
coupled to VLAN enable switch 504. VLAN switch 504 is coiq>led to Ihtemet 106, and 
the VLAN switeh has ports VI, V2, etc. Computers A through G are further coupled to 
SAN switoh 506, which is coupled to a plurality of storage devices or disks D1-D5. The 
SAN switoh 506 has ports SI, S2, etc. A control plane inechanism 508 is 
communicatively coupled by control paths and data paths to SAN switch 506 and to 
VLAN switch 504. The control plane is able to send control commands to these devices 
through the control ports. 

For the sake of simplicity and exposition, the number of computmg elements in 
FIG. 5 is a small number. In practice, a large number of computers, e.g., thousands or 
more, and an equally large nxunber of storage devices form the computing grid. In such 
larger structures, multiple SAN switches are interconnected to form a mesh, and multiple 
VLAN switches are interconnected to form a VLAN mesh. For clarity and simplicity, 
however, FIG. 5 shows a single SAN switch and a single VLAN switch. 

Initially, all computers A-G are assigned to the idle pool until the control plane 
receives a request to create a VSF. All ports of the VLAN switch are assigned to a 
specific VLAN which we shall label as VLAN I (for the idle zone). Assume that the 
control plane is asked to construct a VSF, containing one load balancer/firewall and two 
Web servers connected to a storage device on the SAN. Requests to control plane may 
arrive through a management int^^gice or other computing client 
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In response, the control plane assigns or allocates CPU A as the load 
balancer/firewall, and allocates CPUs B and C as the Web servers. CPU A is logically 
placed in SAN Zone 1, and pointed to a bootable partition on a disk that contains 
dedicated load balancing/firewalling software. The term 'pointed to*' is used for 
convenience and is intended to indicate that CPU A is given, by any means, information 
sufficient to enable CPU A to obtain or locate appropriate software that it needs to 
operate. Placement of CPU A in SAN Zone 1 enables CPU A to obtain resources from 
disks that are controlled by the SAN of that SAN 2k>ne. 

Tlie load balancer is configured by the control plane to know about CPUs B and C 
as the two Web servers it is supposed to load balance. The JBrewall configuration protects 
CPUs B and C against unauthorized access fit>m the Internet 106, CPUs B and C are 
pointed to a disk partition on the SAN that contains a bootable OS image for a particular 
operating system (e.g., Solaris, Linux, NT etc) and Web server application software (e.g., 
Apache). The VLAN switch is configured to place ports vl and v2 on VLAN 1, and 
ports v3, v4, v5, v6 and v7 on VLAN 2, The control plane configures the SAN switch 
506 to place Fibre-Channel switch ports si, s2, s3 and s8 into SAN zone 1 . 

A description of how a CPU is pointed to a particular disk drive, and what this 
means for booting up and shared access to disk data, is provided further herein. 

FIG. 6 is a block diagram of the resulting the logical connectivity of computing 
elements, which are collectively called VSF 1. Disk drive DDI is selected from among 
storage devices Dl, D2, etc. Once the logical structure as shown in FIG. 6 is achieved, 
CPUs A, B, C are given a power-up command. In response, CPU A becomes a dedicated 
load balancer/firewall-<Jomputing element, and CPUs B, C become Web severs. 

Now, assxune that because of a policy-based rule, the control plane determines that 
another Web server is required in VSF 1 . This may be caused, for example, by an 
increased number of requests to the Web site and the customer's plan permits at least . 
three Web servers to be added to VSF 1 . Or it may be because the organization that owns 
or operates the VSF wants another server, and has added it through an administrative 
mechanism, such as a privileged Web page that allows it to add more servers to its VSF. 

In response, the control plane decides to add CPU D to VSF 1. In order to do this, 
the control plane will add CPU D to VLAN 2 by adding ports v8 and v9 to VLAN 2. 
Also, CPU D's SAN port s4 is added to SAN zone 1 . CPU D is pointed to a bootable 
portion ofthe SAN storage that boots up and runs as a Web server. CPUD also gets 
read-only access to the shared data on flie SAN, which may consist of Web page contents. 
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executable server scripts, etc. This way it is able to serve Web requests intended for the 
s^erfennmudi as CPUs B and C serve requests. The control plane will also configure 
the load balancer (CPU A) to include CPU D as part of the server set which is bemg load 
balanced. 

CPU D is now booted 15), and the size of the VSF has now increased to three Web 
servers and 1 load balancer. FIG. 7 is ablock diagram of the resulting logical 
connectivity. 

Assume that the control plane now receives a request to create anotiier VSF, 
which it will name VSF 2, and which needs two Web savers and one load 
balancet/firewalL The control plane allocates CPU E to be the load balancei/firewall and 
CPUsF,Gtobe&eWebs«rvas. a configures CPU B to know about CPUs F, Gas the 
two conq)uting elements to load balance against . 

To unplement this configuration, the control plane will configure VLAN switch 
504 to include port vlO, vll in VLAN 1 (that is, connected to the hitemet 106) and ports 
vl2,vl3andvl4,vl5tobeinVLAN3. Shnilarly, it configures SAN switdhi 506 to 
include SAN ports s6 and s7 and s9 in SAN zone 2; This SAN zone includes the storage 
containing the software necessary to run CPU E as a load-balancer and CPUs F and G as 
Web servers that use a shared read-only disk partition contained in Disk D2 in SAN zone 
2. 

FIG. 8 is a block diagram of the resulting logicd connectivity. Although two 
VSFs (VSF 1, VSF 2) share the same physical VLAN switch and SAN switch, flie two 
VSFs are logically partitioned. Users who access CPUs B, C, P, or the enterprise that 
owns or operates VSF 1 can only access the CPUs and storage of VSF 1. Such users 
cannot access the CPUs or storage of VSF 2. This occurs because of the combination of 
the separate VLANs and the 2 firewalls on the only shared segment (VLAN 1), and the 
differrat SAN zones iQ which the two VSFs are configured. 

Further assume that later, the control plane decides that VSF 1 can now fell back 
down to two Web servers. This may be because the temporary increase in load on VSF 1 
has decreased, or it may be because of some other administrative action takai. hi 
response, the control plane will shut down CPU D by a special command that may 
include powering down the CPU. Once the CPU has shut down, the control plane 
removes ports v8 and v9 from VLAN 2, and also removes SAN port s4 from SAN zone 1. 
Port s4 is placed in an idle SAN zone. The idle SAN zone may be.designated, for 
example, SAN Zone I (for Idle) or Zone 0. 
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Some time later, the control plane may decide to add another node to VSF 2. This 
may be because the load on the Web servers in VSF 2 has tenqporaiily increased or it may 
be due to other reasons. Accordingly, the control plane decides to place CPU D m VSF 2, 
as indicated by dashed path 802. In order to do this^ it configures the VLAN switch to 
include ports v8, v9 in VLAN 3 and SAN port s4 in SAN zone 2. CPU D is pointed to 
the portion of the storage on disk device 2 that contains a bootable image of the OS and 
Web server software required for servers in VSF 2. Also, CPU D is granted read-only 
access to data in a file system shared by the other Web servers in VSF 2. CPU D is 
powered back up, and it now runs as a load-balanced Web server in VSF 2, and can no 
longer access any data in SAN zone 1 or the CPUs attached to VLAN 2. In particular, 
CPU D has no way of accessing any element of VSF 1, even though at an earlier point in 
time it was part of VSF 1. 

Further, in this configuration, the security perimeter enforced by CPU E has 
dynamically expanded to include CPU D. Thus, ^bodiments provide dynamic 
firewalling that automatically adjusts to properly protect computing elements that are 
added to or rraioved from a VSF. 

For purposes of explanation, embodiments have been described herein in the 
context ofport-based SAN zoning. Othertypesof SAN zoning may also be used For 
example, LUN level SAN zoning may be used to create SAN zones based upon logical 
volxmaes within disk arrays. An example product that is suitable for LUN level SAN 
zoning is the Volume Logics Product fit>m EMC CorporatioiL 

DISK DEVICES ON THE SAN 

There are several ways by which a CPU can be pointed to a particular device on 
the SAN, for booting up purpose, or for accessing disk storage which needs to be shared 
with other nodes, or otherwise proyided with information about where to find bootup 
programs and data. 

One way is to provide a SCSt-to-Fibre Channel bridgmg device attached to a 
cornputing element and a SCSI inter&ce for the local disks. By routing that SCSI port to 
the right drive on flie Fibre-Channel SAN, the compute can accesis the storage device on 
the Fibre-Chaimel SAN just as it would access a locally attached SCSI disk. Therefi>re, 
softwiare such ais boot-up software sinq)ly boots off the disk device on the SAN just as it 
would boot off a locally attached SCSI disk. 
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Another way is to have a Fibre-Channel interface on the node and associated" 
device-driver and boot ROM and OS software that permits the Fibre-Channel inter&ce to 
be used as a boot device. 

Yet anotiier way is to have an interfece card (e.g., PCI bus or Sbus) which appears 
to be a SCSI or IDE device controller but that in turn communicates over the SAN to 
access the disk. Operating systems such as Solaris integrally provide diskless boot 
functions that can be used in this alternative. 

Typically fliere will be two kinds of SAN disk devices associated wilh a given 
node. The first is one which is not logically shared witii oth^ computing elemrats, and 
constitutes what is normally a per-node root partition containing bootable OS images^ 
local configuration files, etc. This is the equivalent of the root file system on a Unix 
syst^n. 

The second kind of disk is shared storage with other nodes. The kfaid of sharing 
varies by tiie OS software running on the CPU and the needs of the nodes accessmg the 
shared storage. If tiie OS provides a cluster file system that allows read/write access of a 
shared-disk partition between multiple nodes, the shared disk is mounted as such a cluster 
file system. Similarly, the system may use database software such as Oracle Parallel 
Server that permits multiple nodes running in a cluster to have concurrent read/write 
access to a shared disk. In such cases, a shared disk is abeady designed into fbe base OS 
and plication software. 

For operating systems where such shared access is not possible, because the OS 
and associated apphcations cannot manage a disk device shared with other nodes, the 
shared disk can be mounted as a read-only device. For many Web applications, having 
read-only access to Web related files is sufficient. For example, in Unix systems, a 
particular file system may be mounted as read-only. 

MULTI-SWITCH COMPUTING GRID 

The configuration described above in connection with FIG. 5 can be expanded to a 
large number of computing and storage nodes by interconnecting a plurality of VLAN 
switches to form a large switched VLAN fabric, and by intCTconnecting multiple SAN 
switches to form a large switched SAN mesh. In this case, a computing grid has the 
architecture generally shown in FIG. 5, except fliat the SANA^LAN switched mesh 
contains a very large number of ports for CPUs and storage devices. A numbw of 
computing elements running the control plane can be physically connected to the control 
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ports of the VLAN/SAN switches, as described fiirthisr below, fiiterconnection of 
multiple VLAN switches to create complex multi-campus data networks is known in this 
field. See, for example, G. Haviland, ''Designing High-Performance Campus Mranets 
witii Multilayer Switching," CSsco Systems, Inc., and information available ftom 
Brocade. 

SANARCmreCTURE 

The description assumes that the SAN comprises Fibre-Channel switches and disk 
devices, and potentially Fibre-Chamiel edge devices such as SCSI-to-Fibre Chamiel 
bridges. However, SANs may be constructed using altemative technologies, such as 
Gigabit Ethernet switches, or switches that use other physical layer protocols. In 
particular, there are eflforts currently underway to construct SANs over IP networks by 
r unnin g the SCSI protocol over IP. The methods and architecture described above is 
ad^table to these altemative methods of constracting a SAN, When a SAN is 
constructed by running a protocol hke SCSI over IP over a VLAN capable layer 2 
environment, then SAN zones are created by mapping them to different VLANs. 

Also, Network Attached Storage (NAS) may be used, which works over LAN 
technologies such as fast Efliemet or Gigabit Ethernet With this option, different 
VLANs are used in place of the SAN zones in order to enforce security and the logical 
partitioning of the computing grid. Such NAS devices typically support network file 
systems such as Sun's NSF protocol, or Microsoft's SMB, to allow multiple nodes to 
share the same storage. 

CONTROL PLANE IMPLEMENTATION 

As described herein, control planes may be implemmted as one or more 
processing resources that are coiqiled to control and data ports of the SAN and VLAN 
switches. A variety of control plane implementations may be used and the invention is 
not limited to any particular control plane inq)lementation. Various aspects of control 
plane implementation are described in more detail in tiie following sections: 1) control 
plane architecture; 2) master segment manage election; 3) administrative fimctions; aind 
4) policy and security considerations. 

1. Control Plane Architecture 
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According to one embodiment, a control plane is inqilemmted as a control 
process hierarchy; Hie control process hierarchy g^erally includes one or more master 
segment manager mechanisms that are commumcatively cpiqpled to and control one or 
more slave segment manager mechanisms. The one or more slave segment manager, 
mechanisms control one or more farm managers. The one or more farm managers 
manage one or more VSFs. The master and slave segment manager mechanisms may be 
implemaited in hardware circuitry, computer software, or any combination fliereof 

FIG. 9 is a block diagram 900 that illustrates a logical relationship between a 
control plane 902 and a computing grid 904 according to one embodiment Control plane 
902 controls and manages computing, networking and storage elements contained in 
computing grid 904 through special control ports or interfeces of the networking and 
storage elements in computing grid 904. Computing grid 904 includes a number of VSFs 
906 or logical resource groups created in accordance with an embodiment as previously 
described herein. 

According to one embodiment, control plane 902 includes a master segment 
manager 908, one or more slave segment managers 910 and one or more farm managers 
912. Master segment manager 908, slave segment managers 910 and farm managers 912 
may be co-located on a particular computing platform or may be distributed on multiple 
computing platforms. For purposes of explanation, only a single master segment manager 
908 is illustrated and described, however, any number of master segment managers 908 
may be enq)loyed. 

Master segment manager 908 is communicatively coupled to, controls and 
manages slave segment managers 910. Each slave segment manager 910 is 
communicatively coupled to and manages one or more farm managers 912. According to 
one embodiment, each farm manager 912 is co-located on the same connputing platform 
as die corresponding slave segment managa:s 910 with which it is conmmnicadvely 
coupled. Farm managers 912 establish, configure and maintain VSFs 906 on confuting 
grid 904. According to one embodiment, each &rm managor 912 is assigned a single 
VSF 906 to manage, however, farm managers 912 may also be assigned multiple VSFs 
906. Farm managers 912 do not communicate directly with each other, but only Uiroug^ 
their respective slave segment managers 910. Slave segment managers 910 are 
responsible for monitoring the status of fhsk assigned farm managers 912. Slave segment 
managers 910 restart any of their assigned &rm managers 912 that have stalled or Med. 
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Master segment manager 908 monitors the loading of VSFs 906 and determines 
an amoimt of resources to be allocated to each VSF 906. Mzster segment manager 908 
flien instructs slave segment managers 910 to allocate and de^allocate resources for VSFs 
906 as appropriate through faxm managers 912. A variety of load balancing algorithms 
may be inq)Iemented depending upon the requirements of a particular q)p]ication and the 
invention is not limited to any particular load balancing approach. 

Master segment manager 908 monitors loading information for the computing 
platforms on which slave segment managers 910 and farm managers 912 are executing to 
determine whethCT computing grid 904 is being adequately serviced. Master segment 
manager 908 allocates and de-allocates slave segment managers 910 and instructs slave 
segment managers 910 to allocate and de-allocate fann managers 912 as necessary to 
provide adequate managemait of computing grid 904. According to one embodiment, 
master segment manager 908 also manages the assigranent of VSFs to farm managers 912 
and the assignment of farm managers 912 to slave segment manage 910 as necessary to 
balance the load among farm managers 912 and slave segment managers 910. According 
to one embodiment, slave segment managers 910 actively communicate with master 
segment manager 908 and request changes to computing grid 904 and to request 
additional slave segment managers 910 and/or farm managers 912. If a processing 
platform feils on which one or more slave segment managers 910 and one or more farm 
managers 912 are executing, then master segment manager 908 reassigns the VSFs 906 
fiom the farm managers 912 on the failed computing platform to othor farm managers 
912. hi this situation, master segment manager 908 may also instract slave segment 
managers 910 to initiate additional farm managers 912 to handle the reassignment of 
VSFs 906. Actively managing tiie number of computational resources allocated to VSFs 
906, the number of active farm managers 912 and slave segment managers 910 allows 
overall power consumption to be controlled.. For example, to conserve power master 
segment manager 908 may shutdown computing platforms that have no active slave 
segment mangers 910 or farm manage 912. The power savings can be significant with 
large conq)Uting grids 904 and control planes 902. 

According to one embodiment, mast^ segment manager 908 manages slave 
segment manage 910 using a registry.. The registry contains information about current 
slave segment managers 910 such as their state and assigned farm managers 912 and 
assigned VSFs 906. As slave segment managers 910 are allocated and de-allocated, the 
registry is updated to reflect the change in slave segment managers 910. For example. 
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when a new slave segment manager 910 is instantiated by master segment manager 908 
and assigned one or niore VSFs 906, the registry is updated to reflect the oreation of the 
new slave segment manager 910 and its assigned farm managers 912 and VSFs 906. 
Master segment manager 908 may then periodically examine the r^istry to detennine 
how to best assign VSFs 906 to slave segment managers 910. 

According to one embodiment, the registry contains information about master 
segment manager 908 that can be accessed by slave segment manage 910. For example, 
the registry may contain data that identifies one or more active master segment managers 
908 so that when a new slave segment manager 910 is created, the new slave segmoxt 
manager 910 may check the registry to learn the identity of the one or more master 
segment managers 908. 

The registry may be implemented in many forms and the invention is not limited 
to any particular implem^tation. For example, the registry may be a data file stored on a 
database 914 within control plane 902. The registry may instead be stored outside of 
control plane 902. For exanq)le, the registry may be stored on a storage device in 
computing grid 904, In this example, the storage device would be dedicated to control 
plane 902 and not allocated to VSFs 906. 

2. Master Segment Manager Election 

In general, a mast^ segment manager is elected when a control plane is 
established or after a failure of an existing master segment manager. Although there is 
generally a single master segment manager for a particular control plane, there may be 
situations where it is advantageous to elect two or more mast^ segmentmanagers to co- 
manage the slave segment managers in tiie control plane. 

According to one embodiment, slave segment manage in a control plane elect a 
mastCT s^^lent manager for that control plane, hi the simple case where there is no 
master segment manager and only a single slave segment manager, then the slave 
segment manager becomes the master segment manager and aUocates additional slave 
segment managers as needed. If there are two or more slave segment manage then the 
two or more slave processes elect a new master segment manager by vote, e.g., by a 
quorum. • 

Since slave segment managers in a control plane are not necessarily persistent, 
particular slave segment manage may be selected to participate in a vote. For exanD9)le, 
according to one embodiment, the register includes a timestamp for each slave segment 
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manager that is periodically updated by each slave segment manager. The slave segment 
manage with timestamps that have been most recently updated, as detemnned according 
to specified selection criteria, are most likely to still be executing and are selected to vote 
for a new master segment manager. For example, a specified number of the most recent 
slave segment managers may be selected for a vote. 

According to another embodiment, an election sequence number is assigned to all 
active slave segment managers and a new master segment manager is determined based 
upon the election sequence numbers for the active slave segment managers. For example, 
the lowest or hi^est election sequence number may be used to select a particular slave 
segment manager to be the next (or first) master segment manager. 

Once a master segment manager has been established, the slave segment managers 
in the same control plane as the master segment manager periodically perform a healtii 
check on the mast^ segment manager by contacting (ping) the current master segment 
manager to determine whether the master segment manager is still active. If a 
determination is made that the current master segment manager is no longer active, then a 
new master segment manager is elected. 

FIG. 10 depicts a state diagram 1000 of a master segment manager election 
according to an embodiment In state 1002, which is the slave segment manage main 
loop, the slave segment manager waits for die expiration of a ping timer. Upon expiration 
of the ping timer, state 1 004 is entered. In state 1 004, the slave segment manage pings 
the master segment manager. Also in state 1004, timestamp (TS) for the slave segment 
manage is updated. If the master segment manager responds to die ping, then the mast^ 
segment manager is still active and control returns to state 1002. If no response is 
received from the master segment manage after a specified period of time, then state 
1006 is entered. 

in state 1006, an active slave segment manager list is obtained and control 
proceeds to state 1008. Instate 1008, a check is made to determine whetiieroth^ slave 
segment managers have also not received a response fix>m the master segment manager, 
histead of sending messages to slave segment managers to make this det^mination, fiiis 
information may be obtained fix>m a database. If ttie slave segment manage do not 
agree that master segment manager is no longer active, i.e., one or more of the slave 
segment managers received a timely response fiom the master segment manager, fhm it is 
presumed that the current master segment manager is still active and control returns to 
state 1002. If a specified number of the slave s^ment managers have not received a 
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timely response from the cuireat master segment manage, then it is assmned tbat the 
cmreot master segment manager is "dead", i.e., no longer active, and control proceeds to 
state 1010. 

In state 1010, tiie slave segment manager Ifaat initiated the process retrieves a 
cmrent election nmnber fix)m an election table and the next election nmnber fiom a 
database. The slave segment manager then updates the election table to include an entry 
that specifies the next election number and a unique address into a master election table. 
C^ontrol then proceeds to state 1012 where the slave segment manager reads the lowest 
sequence number for the current election niunber. In state 1014, a detemiination is made 
whether the particular slave segment manager has the lowest sequence number. If not, 
then control returns to state 1002. If so, then control proceeds to state 1016 where Ihe 
particular slave segment manager becomes the master segm^t manager. Control then 
proceeds to state 1018 where the election number is incremented. 

As described above, slave segment managers are generally responsible for 
servicing their assigned VSFs and allocating new VSFs in response to instructions Gcom 
the master segment manager; Slave segment managers are also responsible for checking 
on tiie master segment manager and electing a new master segment manager if necessary. 

FIG. 1 1 is a state diagram 1100 that illustrates various states of a slave segment 
manager according to an anbodiment. Processing starts in a slave segment manager start 
state 1 102. From state 1 102, control proceeds to state 1 104 m response to a request to 
confirm the state of the current master segment manager. la state 1 104, the slave segment 
manager sends a ping to the current master segment manager to determine whether the 
current master segment manager is still active. If a timely response is received finom the 
current master segment manager, tiie. control proceeds to state 1 106. In state 1 106, a 
message is broadcast to other slave segment managers to indicate that the master segment 
manager responded to the ping. From state 1 106, control returns to start state 1 102. 

In state 1 104 if no timely mastCT respoiise is recdved, then control proceeds to 
state 1108. Instate 1108, a message is broadcast to other slave segment managers to 
indicate that the master segment manager did not respond to the ping. Control then . 
returns to start state 1 102. Note that if a sufficient number of slave segment manage do 
not recdve a response fiom the cunrent master segment manager, tiien a new n^ . 
segment manager is elected as described herein. 
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From start state 1 102, control proceeds to state 1110 i^on receipt of a request 
fiom the master segmeat manager to restart a VSF. In state 1110>aVSF is restarted and 
control returns to start state 1 102. 

As described above, a master segment manager is generally responsible for 
ensuring that VSFs in the computing grid controlled by the master segment manager are 
adequately serviced by one or more slave segment managers. To accomplish this, the 
master segment manager performs regular health checks on all slave segment managers in 
the same control plane as the master segment manage. According to one embodiment, 
master segment manager 908 periodically requests status information firom slave segment 
managers 910. The information may include, for example, which VSFs 906 are being 
serviced by slave segment managers 910. If a particular slave segment manager 910 does 
not respond in a specified period of time, master segment manager 908 attempts to restart 
the particular slave segment manager 910. If the particular slave segment manager 910 
cannot be restarted, thm mast^ segment manager 908 re-assigns the farm managers 912 
&om the &iled slave segment manager 910 to another slave segment manager 910. 
Master segment manager 908 may then instantiate one or more additional slave segment 
managers 910 to re-balance the process loading. Accordiiig to one embodiment, master 
segment manager 908 monitors the health of the computing platforms on which slave 
segment managers 910 are executing. If a computing platform fails, then master segment 
manager 908 reassigns the VSFs assigned to fami managers 912 on the failed computing 
platform to farm managers 912 on ano&er conoiputing platform. 

FIG. 12 is a state diagram 1200 for a master segment manager. Processing starts 
in a mast^ segment manage start state 1202. From state 1202, control proceeds to state 
1204 when master segment manager 908 makes a periodic health check or request to 
slave segment managers 910 in control plane 902. From state 1204, if all slave segment 
managers 910 respond as expected, tfien control returns to state 1202. This occurs if all 
slave segment managers 910 provide the specified information to master segment 
manage 908, indicating tiiat all slave segmmt managers 910 are operating normally. If 
one or more slave segfnent managers 910 dther don't respond, or the response dtibierwise 
indicates that one or more slave segment managers 910 have failed, then control proceeds 
to state 1206. 

In state 1206, master segment manager 908 attempts to restart the failed slave 
segment managers 910. Thismaybeacconq)lishedinsev^ ways. For example, mast^ 
segment manager 908 may send a restart message to a non-responsive or failed slave 
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segmeQt manager 910. From state 1206, if all slave segment managers 910 respond as 
expected, i.e., have been successfully restarted, then control returns to state 1202. For 
example, when a failed slave segment manager 910 is successfully restarted, the slave 
segment manager 910 sends a restart confirmation message to master segment manager 
908. From state 1206, if one or more slave segmmt managers have not been successfiiUy 
restarted, then control proceeds to state 1208. This situation may occur if mast^ segment 
manager 908 does not receive a restart confirmation message fiom a particular slave 
segment manager 910. 

In state 1208, master segment manager 908 detennines the current loading of the 
machines on which slave segment managers 910 are executing. To obtain the slave 
segment manager 908 loading information, master segment manager 908 polls slave 
segment managers 910 directly or obtains the loading information firom anodier location, 
for example from database 914. The invention is not limited to any particular ^proach 
for master segment manager 908 to obtain the loading information for slave segment 
managers 910. 

Control then proceeds to state 1210 where the VSFs 906 assigned to the feiled 
slave segment managers 910 are re-assigned to other slave segment managers 910. The 
slave segment managers 910 to which the VSFs 906 are assigned inform master segment 
manager 908 when the reassignment has beai completed. For example, slave segment 
managers 910 may send a reassignment confirmation message to master segment 
manager 908 to indicate that the reassignment of VSFs 906 has been successfully 
completed. Control remains in state 1210 until reassignment of all VSFs 906 associated 
with the failed slave segment managers 910 has been confirmed. Once confibrmed, 
control returns to state 1202. 

Instead of reassigning VSFs 906 associated with a failed slave segment manager 
910 to other active slave segment managers 910, master segment manager 908 may 
allocate additional slave segment managers 910 and then assign those VSFs 906 to the 
new slave segment managers 910. The choice ofwhether to reassign VSFs 906 to 
existing slave segment managers 910 or to new slave segment manage 910 depmds, at 
least in part, on latencies associated witti allocating new slave segment manages 910 and 
latencies associated with reassigning VSFs 906 to an existing slave segment manager 
910. Ei&er egiproach may be used dq)ending iq>on the requirements of a particular 
application and Hxq invention is not limited to either qyproach. 
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3. Administrative Functions 

According to one embodinient^ control plane 9(Q 
global grid manager. Control plane 902 provides billing, fault, capacity, loading and 
otfier computing grid information to the global grid manager. FIG. 13 is a blodc diagram 
1300 that illustrates llie use of a global grid manager according to an embodiment 

In FIG. 13, a computing grid 1300 is partitioned into logical portions called grid 
segments 1302. Each grid segment 1302 includes a control plane 902 that controls and 
manages a data plane 904. In this example, each data plane 904 is the same as the 
computing grid 904 of FIG. 9, but are referred to as "data planes" to illustrate the use of a 
global grid manager to manage multiple control planes 902 and data planes 904, i.e., grid 
segments 1302. 

Each grid segment is coromunicatively coupled to a global grid manager 1304. 
Global grid manager 1304, control planes 902 and computing grids 904 may be co- 
located on a single computing platform or may be distributed across multiple conq)uting 
platfonns and the invention is not limited to any particular implementation. 

Global grid manager 1304 provides centralized management and services for any 
number of grid segments 1302. Global grid manager 1304 may collect billing, loading 
and other information from control planes 902 used in a variety of adndnistrative tasks. 
For example, the billing information is used to biU for services provided by computing ' 
grids 904. 

4. Policy and Security Considerations 

As described herein, a slave segment manager in a control plane must be able to . 
communicate with its assigned VSFs in a computing grid. Similarly, VSFs in a 
computing grid must be able to conmiumcate with their assigned slave segmmt manager. 
Further, VSFs in a computing grid must not be allowed to communicate with each other 
to prevent one VSF from in any way causing a change in the configuratiori of anotiier 
VSF. Various ^roaches for implementing tidesepoUdes are desOTbedherem 

FIG. 14 is a block diagram 1400 of an arcbitectare for connecting a control plane 
to a confuting grid according to an embodiment Control ("CTL'O ports of VLAN 
switches (VLAN S Wl througjh VLAN SWn), collectively identified by referaice numeral 
1402, and SAN switches (SAN SWl throng SAN SWn), collectively identified by 
reference numeral 1404, are connected to an Ethernet subnet 1406. Bthemet subnet 1406 
is connected to a plurality of conq)uting elements (CPUl, CPU2 throu^ CPUn), that are 
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collectively ideatified by reference numeral 1408. Thus, only con5)uting elonmts of 
control plane 1408 are conmunicatively coupled to the control ports (CTL) of VLAN 
switches 1402 and SAN switches 1404. This configuration prevents conoputing elements 
in a VSF (not illustrated), fiom nhnrigitig the m^nbership of the VLANs and SAN zones 
associated with itself or any other VSF. This approach is also q)plicable to situations 
where the control ports are serial or parallel ports. M these situations, the ports are 
coupled to the control plane 1408 conq>uting elements. 

FIG. 15 is a block diagram 1 500 of a configuration for connecting control plane 
computing elements (CP C3*U1, CP CPU2 through CP CPUn) 1502 to data ports 
according to an embodiment In this configuration, control plane computing elements 
502 periodically send a packet to a control plane agent 1504 that acts on behalf of control 
plane com5)uting elements 1502; Control plane agent 1504 periodically polls computing 
elements 502 for real-time data and sends the data to control plane computing elements 
1502. Each segment manager in control plane 1502 is communicatively coupled to a 
control plane (CP) LAN 1506. CP LAN 1506 is communicatively coupled to a special 
port V17 of VLAN Switch 504 through a CP firewall 1508. This configuration provides 
a scalable and secure means for control plane computing elements 1502 to collect real- 
time information fix>m computing elements 502. 

FIG. 16 is a block diagram 1600 of an architecture for connecting a control plane 
to a computing grid according to an embodiment. A control plane 1602 includes control 
plane computing elements CP CPUl, CP CPU2 tiirough CP CPUn. Each control plane 
con5>uting element CP CPUl, CP CPU2 through CP CPUn in control plane 1602 is 
communicatively coupled to a port SI, S2 through Sn of a plurality of SAN switches that 
collectively form a SAN mesh 1604. 

SAN mesh 1 604 includes SAN ports So, Sp that are communicatively coiq)led to 
storage devices 1606 that contain data that is private to control plane 1602. Storage 
devices 1606 are depicted in FIG. 16 as disks for purposes of explanation. Storage 
devices 1 606 may be implemented by any type of storage medium and tiie invention is . 
not limited to any particular type of storage medium for storage devices 1606. Storage 
devices 1606 are logically located in a control plane private storage zone 1608. Control 
plane private storage zone 1608 is an area where control plane 1602 maintains log files, 
statistical data, current control plane configuration information and software that 
inqilements control plane 1602. SAN ports So, Sp are only part of tiie control plane 
private storage zone and are never placed on any otiier SAN zone so that only compnting 
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elements in control plane 16Q2 can access the storage devices 1606. Furth^more, ports 
SI, S2 fhrou^ Sn, So and Sp are in a control plane SAN zone fbaX may only be 
communicatively coi^led to computing elements in control plane 1602. These ports are 
not accessible by computing elements in VSFs (not illustrated). 

According to one embodiment, when a particular computing element CP CPUl, 
CP CPU2 through CP CPUn needs to access a storage device, or a portion thereof, that is 
part of a particular VSF, the particular computing element is placed into the SAN zone for 
the particular VSF. For example, suppose that computing element GP CPU 2 needs to 
access VSFi disks 1610. In fliis situation, port s2, which is associated with control plane 
CP CPU 2, is placed in the SAN zone of VSFi, which includes port Si. Once computing 
element CP CPU2 is done accessing the VSFi disks 1610 on port Si, computing element 
CP CPU2 is removed j&om the SAN zone of VSFi. 

Similarly, si5)pose computing element CP CPU 1 needs to access VSFj disks 
1612. this situation, computing element CP CPUl is placed in the SAN zone 
associated with VSFj. As a result, port SI is placed in the SAN zone associated with 
VSFj, which includes the zone containing port Sj. Once computing element CP CPUl is 
done accessing the VSFj disks 1612 connected to port Sj, computmg element CP CPUl is 
removed from the SAN zone associated with VSFj. This ^pioach ensures the integrity 
of control plane computing elements and the control plane storage zone 1608 by tightly 
controlling access to resources using tight SAN zone control. 

As previously described, a single control plane computing element may be 
responsible for managing several VSFs. Accordingly, a single control plane computing 
element must be capable of manifesting itself in multiple VSFs simultaneously, while 
enforcing firewalling between the VSFs according to policy rules estabUshed for each 
control plane. Policy rules may be stored in database 914 (FIG. 9) of each control plane 
or implemented by central segment manage 1302 (PIG. 13). 

According to one embodiment, ti^t binding between VLAN taggmg and IP 
addresses are used to prevent spoofing attacks by a VSF smce physical switch) port- 
based VLAN tags are not spoofable. An incontiing IP packet on a given VLAN interface 
must have the same VLAN tag and IP address as the logical interface on which the packet 
arrives. This prevents IP spoofing attacks where a malicious server in a VSF spoo& the 
source IP address of a server in another VSF and potentially modifies the logical structure 
of another VSF or otherwise subverts the security of computing grid fimctions. 



-28- 



wo 02/03203 



PCTAJSOl/19053 



Ciicumventing fbis VLAN tagging kpproach requires physical access to the coinputing 
grid wWch can be prevented usiiig higji security (Class A) data centOT^ 

A variety of netwodc fiame taggmg formats may be used to tag data packets and 
the invention is not lirnited to any particular tagging format According to one 
embodiment, TRKK 802.1q VLAN tag? are used, although olher formats may also be 
suitable. In tins example, a VLAN/IP address consistency check is performed at a 
subsystrai in the ff stack where 802.1q tag information is preseut to control access, hi 
this ^ample^ computing elements are configure witti a VLAN C£q[>able network int^c&ce 
card (NIC) in a manner that allows fiie computing elements to be communicatively 
coupled to multiple VLANs simultaneously. 

FIG. 17 is a block diagram 1700 of an arrangement for enforcing tight binding 
between VLAN tags and IP addresses according to an embodiment Computing elements 
1702 and 1704 are communicatively coiQ)led to ports vl and v2 of a VLAN switch 1706 
via NICs 1708 and 1710, respectively. VLAN switch 1706 is also communicatively 
coiq)led to access switches 1712 and 1714. Ports vl and v2 are configured in tagged 
mode. According to one embodiment, IEEE 802. Iq VLAN tag information.is provided 
byVLAN switch 1706. 

A WIDE AREA COMPUTING GRID 

The VSF described above can be distributed over a WAN in several ways. 

In one alternative, a wide area backbone may be based on Asynchronous Transfer 
Mode (ATM) switching. In this case, each local area VLAN is extended into a wide area 
using Bnulated LANs (ELANs) which are part of the ATM LAN Emulation OLANE) 
standard. In this way, a single VSF can span across several wide area links, such as 
ATM/SONET/OC-12 links. An ELAN becomes part of a VLAN which extmds across 
theATMWAN. 

Alternatively, a VSF is extended across a WAN using a VPN syston. In this 
embodiment, the underlying characteristics of the network become irrelevant, and the 
VPN is used to interconnect two or more VSFs across the WAN to make a single 
distributed VSF. 

Data mirroring technologies can be used in order to have local copies of the data 
in a distributed VSF. Alternatively, the SAN is bridged over tiie WAN using one of 
several SAN to WAN bridging techniques, such as SAN-to-ATM bridging or SAN-to- 
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Gigabit Ettiemet bridging. SANs constructed over IP networks naturally extend over flie 
WAN since IP works well over sach networks. 

Fia ISisablockdiagramofapluralityofVSFsextendedoverWAN 
connections. A San Jose Center, New Yoric Center, and London center are coupled by 
WAN connections. Each WAN connection con5)rises an ATM, ELAN, or VPN 
connection in the manner described above. Each center comprises at least one VSF and at 
least one Idle Pool. For example, the San Jose center has VSFIA and Idle Pool A. In this 
configuration, the computing resources of each Idle Pool of a center are available for 
allocation or assignment to a VSF located in any other center. When such allocation or 
assignment is carried out, a VSF becomes extended over the WAN. 

EXAMPLE USES OF VSFS 

The VSF architecture described in the examples above may be used in the context 
of Web server system. Thus, the foregoing examples have been described in terms of 
Web servers, application servers and database servers constructed out of the CPUs in a 
particular VSF. However, the VSF architecture may be used in many other computing 
contexts and to provide other kmds of services; it is not limited to Web server systems. 

- A DISTRIBUTED VSF AS PART OF A CONTENT DISTRIBUTION 
NETWORK 

In one embodiment, a VSF provides a Content Distribution Network (CDN) using 
a wide area VSF. The CDN is a network of caching serv^ that performs distributed 
caching of data. The network of caching servers may be implemented, for example, usmg 
TrafiBcServer (TS) software commCTcially available fiom Inktomi Corporation, San 
Mateo, California. TS is a cluster aware system; the system scales as more CPUs are 
added to a set of caching TrafGc Server confuting elements. Accordingly, it is well 
suited to a system in wMch adding CPUs is the mechanism for scalixig upwards 

In this configuration, a system can dynamically add more CPUs to tiiat portion of 
a VSF tiiat runs caching softwai^ such as TS, thereby growing the cache capadt^ 
point close to where bursty- Web traffic is occurring. As a result, a CDN may be 
constructed that dynamically scales in CPU and VO bandwidtii in an adq)tive way. 
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- A VSF FORHOSTED INTRANET APPUCATIONS 

There is growing interest in offering Intranet applications such as Enterprise 
Resource Planning (ERP), ORM and CRM software as hosted and managed services. 
Technologies such as Qtrix WinFrame and Citrix MetaFrame allow an entoprise to 
provide Microsoft Windows applications as a service on a thin client such as a Windows 
C£ device or Web browser. A VSF can host such applications in a scalable manner. 

For example, the SAP R/3 ERP software, commeicialiy available fi?om SAP 
Aktiengesellschaft of Germany, allows an enterprise to load balance using multiple 
Application and Database Servers. In the case of a VSF, an enterprise would dynamically 
add more Application Servers (e.g., SAP Dialog S^ers) to a VSF m order to scale up the 
VSF based on real-time demand or other factors. 

Similarly, Citrix Metaframe allows an enterprise to scale up Windows plication 
users on a server farm nmning the hosted Windows applications by adding more Citrix 
servers, hi this case, for a VSF, the Citrix MetaFrame VSF would dynamically add more 
Citrix servers in order to accoromodate more users of Metaframe hosted Windows 
£^pUcations. It will be apparent that many other applications may be hosted in a manna: 
similar to the illustrative examples described above. 

- CUSTOMER INTERACTION Wira A VSF 

Since a VSF is created on demand, a VSF customer or organization that "owns" 
the VSF may interact with the system in various ways m order to customize a VSF. For 
example, because a VSF is created and modified instantly via the control plane, the VSF 
customer may be granted privileged access to create and modify its VSF itself. The 
privileged access may be provided using password authentication provided by Web pages 
and security applications, token card authentication, Kerberos exchange, or other 
^ropriate security elements. 

In one exemplary embodiment, a set of Web pages are served by the computing 
element, or by a separate server. The Web pages enable a customer to create a custom 
VSF, by specifying a number of tiers, the number of computing elements in a particular 
tier, the hardware and software platform used for each elemmt, and things such as what 
kind of Web server, plication server, or database server software shoidd be pre- 
configured on tiiese computing elements. Thus, the customs is provided wifli a virtual 
provisioning console. 
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After flie customer or user enters such piovisiomng infonnatioii, fht control plane 
parses and evaluates the order and queues it for execution. Orders may be reviewed by 
human managers to ensure that they are appropriate. Credit checks of flie ent^rise may 
be run to ensure fiiat it has ^propriate credit to pay for tiie requested services. If the 
provisioning order is {proved, the control plane may configure a VSF fiiat matches the 
order, and retum to the customer a password providing root access to one or more of the 
computing elements in the VSF. The customer nu^ then iq>load master copies of 
plications to execute in die VSF. 

When the enterprise that hosts the computing grid is a for-profit enterprise, the 
Web pages may also receive payment related information, such as a credit card, a PO 
numb^-, electronic check, or other payment method. 

hi another embodiment, the Web pages enable the customer to choose one of 
several VSF service plans, such as automatic growth and shrinkage of a VSF between a 
minimum and maximum number of elements, based on real-time load. The customer 
may have a control value that allows the customer to change parameters such as Tninimum 
number of computing elements in a particular tier such as Web servers, or a time period 
in which tiie VSF must have a minimal amount of server c£q>acity. The parameters may 
be linked to billing software that would automatically adjust the customer's bill rate and 
generate billing log file entries. 

Through the privileged access mechanism the customer can obtain reports and 
monitor real-time information related to usage, load, hits or transactions per second, and 
adjust the characteristics of a VSF based on the real-time information. It will be apparent 
that the foregoing features ofTer significant advantages over conventional manual 
approaches to constructing a server farm, hi the conventional approaches, a user cannot 
automatically influence server fiinn's properties without going through a cumbersome 
manual procedure of adding servers and configuring the server farm in various ways. 

- BILLING MODELS FOR A VSF 

Given the dynamic nature of a VSF, the ent^rise that hosts the computing grid 
and VSFs may bill service fees to customers who own VSFs usu3g a billing model for a 
VSF which is based on actual usage of the computing elements and storage elements of a 
VSF. It is not necessary to use a flat fee billing model. The VSF architecture and 
methods disclosed herein enable a "pay-as-you-go'' billing model because the resources 
of a given VSF are hot statically assigned. Accordingly, a particular customer having a 
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highly variable usage load on its server farm could save mon^ because it would not be 
billed a rate associated with constant peak server edacity, but rather^ a rate that reflects a 
running average of usage, instantaneous usag^ etc. 

For example, an enterprise may operate usmg a billing model that stipulates a flat 
fee for a TninimnTn number of computing elements, such as 10 servers, and stipulates that 
when real-time load requires more than 10 elements, flien the xtsex is billed at an 
incremental rate for the extra servers, based on how many extra servers wa:e needed and 
for the length oftime that they are needed. The units ofsuch bills may reflect the 
resources that are billed! For e9canq>le, bills may be e^qpressed in units such as MIPS- 
hours, CPU-hours, fiiousands of CPU seconds, etc. 

» 

A CUSTOMER VISIBLE CONTROL PLANE API 

In another alternative, the capacity of a VSF may be controlled by providing the 
customer with an application programming interface (API) that defines calls to the control 
plane for changing resources. Thus, an application program prepared by the customer 
could issue calls or requests using the API to adc for more servers, more storage, more 
bandwidth, etc. This alternative may be used when the customer needs the £5)plication 
program to be aware of the computing grid environment and to take advantage of the 
capabilities offered by the control plane. 

Nothing in the above-disclosed architecture requires the customer to modify its 
application for use with the computing grid. Existmg applications continue to work as 
they do in manually configured server farms. However, an application can take 
advantage of the dynamism possible in the computing grid, if it has a better understanding 
of the computing resources it needs based on the real-time load monitoring fimctions 
provided by the control plane. An API of the foregoing nature, which enables an 
^plication program to change the computing capacity of a server farm, is not possible 
using existing manual approaches to constructing a servCT &rm. 

- AUTOMATIC UPDATING AND VERSIONING 

Using the methods and mechanisms disclosed herein, the control plane may cany 
out automatic izpdating and vorsioning of op^:ating system sofiware that is executed in 
computing elemmts of a VSF. llius, the end xiser or customer is not required to worry 
about iq)dating .the operating system with a new patch, bug fix, etc. The control plane can 
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maintain a library of sudi software elemmts as they are received and automatically 
distribute and install them in computing elOTients of all affected VSFs. 

IMPLEMENTATION MECHANISMS 

The computing elements and control plane may be implemented in several forms 
and the invention is not limited to any particular form. In one embodiment, each 
computing element is a general purpose distal computer having the elements shown in 
FIG. 19 except for non-volatile storage device 1910, and the control plane is a general 
purpose digital computer of the type shown in FIG. 19 operating under control of 
program instructions that implement the processes described herein. 

Figure 19 is a block diagram that illustrates a computer system 1900 upon which 
an embodiment of the invention may be hnplemented. Computer system 1900 includes a 
bus 1902 or other conununication mechanism for communicating information, and a 
processor 1904 coupled witii bus 1902 for processmg infonnatiorL Computer system 
1900 also includes a main memory 1 906, such as a random access memory (RAM) or 
oflier dynamic storage device, coupled to bus 1902 for storing information and 
instructions to be executed by processor 1904. Main memory 1906 also may be used for 
storing tenqwrary variables or other intermediate information during execution of 
instructions to be executed by processor 1904. Computer system; 1900 further mcludes a 
read only memory (ROM) 1908 or other static storage device coupled to bus 1902 for 
storing static information and mstructions for processor 1904. A storage device 1910, 
such as a magnetic disk or optical disk, is provided and coi^jled to bus 1902 for storing 
information and instructions. 

Computer system 1900 maybe coupled via bus 1902 to a display 1912, such as a 
cathode ray tube (CRT), for displaymg information to a computer user. An ixsput device 
1914, includmg alphanumeric and othra: keys, is coiq)led to bus 1902 for communicating 
information and command selections to processor 1904. Anolhw type of user input 
device is cursor control 1916, such as a mouse, a trackball, or cursor direction keys for 
communicating direction mforaaation and command selections to processor 1904 and for 
controllmg cursor movement on display 1912. This iiiput device typically has two 
degrees of freedom in two axes; a first axis (e.g., x) and a second axis (e.g., y), ttiat allows 
the device to specify positions in a plane. 

The invention is related to the use of oonq>uter system 1900 for controlling an 
extensible coroputing syst^n. According to one embodimeat of the invention, controlling 
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an extensible computing system is provided by computer system 1900 in response to 
processor 1904 executing one or more sequences of one or more instructions contained in 
main memoiy 1906. Such instructions may be read into main memory 1906 fiom anotho: 
computer-readsible medium, such as storage device 1910, Bcecution of flie sequences of 
instructions contained m main memory 1906 causes processor 1904 to perform the 
process steps described herein. One or more processors in a multi-processing 
arrangement may also be employed to execute the sequences of instructions contained in 
main memory 1906. In alternative embodimmts, hard-wired circuitry may be used in 
place of or in combination with software instructions to implement the invention. Thus, 
embodiments of the invention are not limited to any specific combination of hardware 
circuitry and software. 

The term "conq>uter-readable medium" as used herein refers to any medium that 
participates in providing instructions to processor 1904 for executioiL Such a medium 
may take many forms, including but not limited to, non-volatile media, volatile media, 
and transmission media. Non-volatile media includes, for example, optical or magnetic 
disks, such as storage device 1910. Volatile media includes dynamic memory, such as 
main manory 1906. Transmission media includes coaxial cables, copper wire and fiber 
optics, including the wires that comprise bus 1902. Transmission media can also take the 
form of acoustic or light waves, such as those generated during radio wave and infirared 
data commimications. 

Common forms of computer-readable media include, for example, a floppy disk, a 
flexible disk, hard disk, magnetic tape, or any other magnetic medium, a CD-ROM, any 
other optical medium, punch cards, paper tape, any otiier physical medium with patterns 
of holes, a RAM, a PROM, and EPROM, a FLASH-EPROM, any other memory chip or 
cartridge, a carrier wave as described hereinafter, or any other medium from which a 
computer can read. 

• Various forms of coniputer reiadable media may be involved in carrying one or 
more sequences of one or more instructions to processor 1904 for execution. For 
example, the instructions may initially be carried on a magnetic disk of a remote 
compute. The remote conq>uter can load tiie instmctions into its dynamic memory and 
send the instructions over a telq)hone line using a modem. Amodranlocaltocorrqputer 
system 1900 can receive the data on the telephone line and use an infirared transmitter to 
convert die data to an infrared sigoaL Aninfiareddetector coupled to bus 1902 can 
receive the data carried in the infrared signal and place the data on bus 1902. Bus 1902 
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carries the data to main mOTiory 1906, from which processor 1904 retrieves and executes 
the instructions. The instructions received by main memory 1906 may optionally be 
stored on storage device 1910 eittter before or after execution by processor 1904. 

Computer system 1900 also includes a communication interface 1918 coiq)led to 
bus 1902. Communication interface 1918 provides a two-way data coimnumcation 
coupling to a network link 1920 that is comiected to a local network 1922. For example, 
communication interface 1918 maybe an integrated services digital network (ISDN) card 
or a modem to provide a data cominimication coimection to a corresponding type of 
telephone line. As another example, communication interface 1918 may be a local area 
network (LAN) card to provide a data communication connection to a compatible LAN. 
Wireless links may also be implemented. In any such implementation, communication 
interface 1918 sends and receives electrical, electromagnetic or optical signals that carry 
digital data streams repres^ting various types of information. 

Network link 1920 typically provides data communication flirough one or more 
networks to other data devices. For example, networic link 1920 may provide a 
coimection through local network 1922 to a host computer 1924 or to data equipment 
operated by an Ihtemet Service Provider (ISP) 1926. ISP 1926 in turn provides data 
coimxiunication services through the worldwide packet data communication network now 
commonly referred to as the "Memef 1928. Local network 1922 and Internet 1928 both 
use electrical, electromagnetic or optical signals that carry digital data streams. The 
signals through the various networks and the signals on network link 1920 and through 
conununication interface 1918, which carry the digital data to and from computer system 
1900, are exemplary forms of carrier waves transporting the information. 

Computer system 1900 can send messages and receive data, including program 
code, through the network(s), network link 1920 and conununication interface 1918. In 
the Internet example, a server 1930 might transmit a requested code for an application 
program through Internet 1928, ISP 1926, local networic 1922 and communication 
interfece 1918. In accordance with the invention, one such downloaded ^plication 
provides for controlling an extensible coniputing system as described herein. 

The received code may be executed by processor 1904 as it is received, and/or 
stored in storage device 1 910, of other non-volatile storage for later executioiL In this 
manner, computer system 1900 may obtain sqiplication code in the form of a carrier wave. 

The computing grid disclosed herein may be compared conceptually to the public 
electric power network that is sometimes called the pow^ grid. The power grid provides 
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a scalable means for many parties to obtain power services through a single wide-scale 
power inftastructura Similarly, the computing grid disclosed herein provides computing 
services to many organizatioiis using a single wide-scale computing infibastnw Usbg 
Ihe power grid, power consumers do not indqjendently manage their own personal power 
equq)meat. For example, there is no reason for a utility consumer to run a personal power 
generator at its facility, or in a shared fecility and manage its capacity and growth on an 
individual basis. Instead, the power grid enables the wide-scale distribution of power to 
vast segments of the population, thereby providing great economies of scale. Similarly, 
the computing grid disclosed herein can provide computing services to vast segments of 
the population using a single wide-scale computing infirastructure. 

In the foregoing specification, the invoition has been described with reference to 
specific embodimmts thereof. It will, however, be evident that various modifications and 
changes may be made thereto without departmg fix)m the broader spirit and scope of the 
invention. The specification and drawings are, accordingly, to be regarded in an 
illustrative rather than a restrictive sense. 
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CLAIMS 

What is claimed is: 

1. A control sqpparatus comprising: 
a master control mechanism; and 

one or more slave control mechanisms conmiiinicatively coiq}ied to fiie master 
control mechanism and being configured to, in response to one or more 
instructions fix>m the master control mechanism, establish a first logical 
resource group that contains a first subset of processing resources and a 
first subset of storage resources by: 

selecting the first subset of processing resources &om a set of processing 
resources, 

selecting the first subset of storage resources firom a set of storage 
resources, and 

causing the first subset of processing resources to be conununicatively 
coupled to the first subset of storage resources. 

2. A control apparatus as recited in Claim 1, wh^ein the master control mechanism 
is a master control process executing on one or more processors and the one or 
more slave control mechanisms are one or more slave processes executing on the 
one or more processors. 

3. A control apparatus as recited m Claim 1, wherein the master control mechanism 
is one or more master processors and the one or more slave control mechanisms 
are one or more slave processors. 

4. A control ^paratus as recited in Claim 1 , wherein the master control mechanic 
is configured to, based upon slave control process mechanism loading, 
dynamically reassign control, between the one or more slave control mechanisms, 
of one or more processing resources &om the subset of processing resources and 
one or more storage resources fit>m the subset of storage resources. 

• 

5. A control apparatus as recited in Claim 1, wherein the masta: control mechanism 
is configured to, based upon slave control process mechanism loading, 
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dynamically allocate one or more additional slave control mechanisms, and 
assign control of one or more processing resources from the subset of processing 
resources and one of more storage resources from tiie subset of storage 
resources to the one or more additional slave control mechanisms. 

6. A control {^paratus as recited in Claim l,.wherein flie niaster control mechanism 
is configured to, based vpon slave control process mechanism loadings 
reassign control to one or more other slave control mechanisms from the one or 

more slave coiitrol mechanisms of one or more particular processmg 
resources from the subset of processing resources and one or more 
particular storage resources from the subset of storage resources that were 
previously assigned to one or more particular slave control mechanisms 
from the one or more slave control niechanisms, and 
dynamically de-allocate tiie one or more particular slave control mechanisms: 

7. A control apparatus as recited in Claim 1, i^dierein the master control mechanism 
is configured to: 

det^mine a status of the one or more slave control mechanisms, 
if one or more particular slave control mechanisms from the one or more slave 
control mechanisms are not responding or fimctioning correctly, &en 
attempting to restart flie one or more particular slave control mechanisms, 
and 

if the one or more particular slave control mechanisms cannot be restarted, 

then 

initiating one or more new slave control mechanisms, and 
reassigning control of processing resources and storage resources 
from the one or more particular slave control mechanisms 
to the one or more new slave control mechanisms. 

8. A control apparatus as recited in Claim 1, wherein the one or more slave control 
mechanisms are configured to: 

detemiine a status of the master control mechanism, and 



-39- 



wo 02/03203 PCT/US01/19a53 

if the master control mechanism has failed or is no longer fimctioning properly, 
elect a new master control mechanism fiom Ihe one or more slave control 
mechanisms. • 

9. A control ^paratus as recited in Claim 1, wherein the one or more instractions 
from the master control mechanism are generated based upon expected processing 
and storage requirements for the first logical resource group. 

10. A control apparatus as recited in Claim 1, wherein the one or more slave control 
mechanisms are further configured to, in response to the one or more instmctions 
from the master control mechanism, perform the following: 

dynamically change the number of processing resources in the first subset of 

processing resources, 
dynamically change the number of storage resources in the first subset of storage 

resources, 

dynamically change the communicative coupling between the first subset of 
processing resources and the first subset of storage resources to reflect 
changes in the number of processing resources in the first subset of 
processing resources and the ninnber of storage resources in the first subset 
of storage resources. 

11. A control qyparatus as recited m Claim 10, wherein changes to the number of 
processing resources in the first subset of processing resources and the number of 
storage resources in the first subset of storage resources is instructed by the master 
control mechanism based upon actual loading of the first subset of processing 
resources and first subset of storage resources. 

12. A control ^aratus as recited in Claim 1, wherein the one or more slave control 
mechanisms are further configured to, in response to the one or more instructions 
fiom the mastCT control* mechanism, establish a second logical resource group fiiat 
contains a second subset of processing resources and a second subset of storage 
resources, wherein the second logical resource group is communicatively isolated 
from the first logical resource groiqp, by: 
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selecting the second subset of processing resources fiom the set of 

processing resources, 
selecting the second subset of storage resources fiom the set of processing 

resources, and 

causing the second subset of processing resources to be communicatively 
coupled to the second subset of storage resources. 

13. A control apparatus as recited in Claim 12, wherein: 

the first subset of processing resources is communicatively coupled to the first 

subset of storage resources using one or more storage area network (SAN) 
switches, 

the second subset of processing resources.is communicatively coupled to the 

second subset of storage resources using ttie one or more SAN switches, 
and 

the second logical resource g^xsp is communicatively isolated Scorn the first 
logical resource group using tagging and SAN zoning. 

14. A control apparatus as recited in Claim 13, wherein SAN zoning is performed 
using port-level SAN zoning or LUN level SAN zoning. 

15. A control apparatus as recited in Claim 1, wherein: 

the master control mechanism is communicatively coupled to a central control 

the master control mechanism is configured to provide loading informatioh for the 
first logical resource gconp to the central control mechanism, and 

the master control mechanism is fiirther configured to generate the one or more 
instructions for the one or more slave control mechanisms based upon one 
or more central control instmctions received from the central control 
mechanism. 

16. A metiiod for managing processixig resources comprising the steps of: 
initiating a master control mechanisn^ and 

initiating one or more slave control mechanisms communicatively coi^led to die 
mast^ control mechanism and being configured to, in response to one or 
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more instnictioiis firom the master control medianism, establish a first 
logical resource group that contains a first subset of processing resources 
and a first subset of storage resources by: 

selecting the first subset of processiug resources from a set of processing 
resources, 

selectmg the first subset of storage resources fix)m a set of storage 
resources, and 

causing the first subset of processing resources to be communicatively 
. coi5)led to flie first subset of storage resources* 

17. A meliiod as recited in Claim 1 6, wherem: 

initiating a master control mechanism includes initiating a master control process 

executii^ on one or more processors, and 
initiating one or more slave control mechanisms includes initiating one or more 

slave processes executing on the one or more processors. 

18. A method as recited in Claim 1 6, wherein: 

initiating a master control mechanism includes initiating one or more master 

control processors, and 
initiating one or more slave control mechanisms includes initiating one or more 

slave processors. 

19. A method as recited in Qaim 16, fiirth^ conq)rising the master control 

mechanism dynamically reassigning control, based upon slave control process 

mechanism loading, between tiie one or more slave control mechanisms, of one or 

more processing resources firom the subset of processing resources and one or 
'i 

more storage resources fiom the subset of storage resources. 

20. A method as recited in Claim 16, fiirther comprising tiie master control 
mechanism, based upon slave control process mechanism loading, 
dynamically allocating one or more additional slave control mechanisms, and 
assigning control of one or more processing resources firom the subset of 

processing resources and one or more storage resources &om the subset of 
storage resources to the one or more additional slave control mechanisms. 
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21. A metixod as recited in Claim 16, furflierconqprising the master control 
mechanism, based xxpon slave control process mechanism loading, 
reassigning control to one or more other slave control mechanisms fiom the one or 

more slave control mechanisms of one or more particular processing 
resources from the subset of processmg resources and one or more 
particular storage resources fiom the subset of storage resources that were 
previously assigned to one or more particular slave control mechanisms 
from the one or more slave control mechanisms, and 
dynamically de-allocating the one or more particular slave control me chanisms . 

22. A method as recited in Claim 1 6, further comprising the master control 
mechanism: 

determining a status of the one or more slave control mechanisms, 
if one or more particular slave control mechanisms from the one or more slave 
control mechanisms are not responding or functioning correctly, then 
attenq)ting to restart the one or more particular slave control mechanisms, 
and 

if the one or more particular slave control mechanisms cannot be restarted, 
then 

initiating one or more new slave control mechanisms, and 
reassigning control of processing resources and storage resoxm^es 
from the one or more particular slave control mechanisms 
to the one or more new slave control mechanisms. 

23. A method as recited in Claim 1 6, further comprising the one or mpre slave control 
mechanisms: 

determining a status of the master control mechanism, and 

if the master control mechanism has &iled or is no longer functioning properly, 

electing a new master control mechanism from the one or more slave 

control mechanisms. 
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24. A method as recited in Qaim 1 6, wherein flie one or more instructions ftom the 
master control mechanism are generated based upon expected processing and 
storage requirements for the first logical resource group. 

25. A method as recited in Claim 16, further comprising the one or more slave control 
mechanisms^ in response to the one or more instructions fi:om the master control 
mechanism, performing the following: 

dynamically r^hanging the number of processing resources in the first subset of 

processing resources, 
dynamically changing the numb^ of storage resources in the first subset of storage 

resources, 

dynamically changbg the communicative coiqpling between tiie first subset of 
processing resources and the first subset of storage resources to reflect 
changes in the number of processing resources in the first subset of 
processing resources and the number of storage resources in the first subset 
of storage resources. 

26. A method as recited in Claim 25, wherein changes to the number of processing 
. resources in the first subset of processing resources and the number of storage 

resburces in the first subset of storage resources is instmcted by the mast^ control 
mechanism based iq>on actual loading of the first subset of processing resources 
and first subset of storage resources. 

27. A method as recited in Claim 16, fiirtiier comprising Ae one or more slave control 
mechanisms, in response to the one or more instructions fix>m the master control 
mechanism, establishing a second logical resource group that contains a second 
subset of processing resources and a second subset of storage resources, wherdn 
the second logical resource group is communicatively isolated fi?om the first 
logical resource group, by: 

selecting the second subset of processing resources &om the set of 

processing resources, 
selectiag die second subset of storage resources from the set of processing 

resources, and 
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causing the seco^d subset of processing resources to be coi^ 
coupled to the second subset of storage resources. 

28. A method as recited in Claim 27, wherein: 

the first subset of processing resources is communicatively coi^led to the first 

subset of storage resources using one or more storage area netwoik (SAN) 
switches, 

the second subset of processing resources is communicatively coupled to flie 

second subset of storage resoim^es using the one or more SAN switches, 
and 

the second logical resource group is communicatively isolated fiom the first 
logical resource group using tagging and SAN zoning. 

29. A method as recited in Claim 28, wherein SAN zoning is performed using port- 
level SAN zoning or LUN level SAN zoning. 

30. A method as recited in Claim 16, wherein: 

the master control mechanism is communicatively coiq)led to a central control 
mechanism, 

the master control mechanism is configured to provide loading information for the 
first logical resource groiq) to the central control mechanism, and 

the master control mechanism is fiirther configured to generate the one or more 
instructions for the one or more slave control mechanisms based xspon one 
or more central control instmctions received &om the central control 
mechanisnL 

31. A computer-readable medium carrying one or more sequences of one or more 
instructions for Tn^aging processing resources, wherein execution of the one or 
more sequences of one or more instmctions by one or more processors causes the 
one or more processors to perform tiie steps of: 

initiating a master control mechanism; and 

initiating one or more slave control mechanisms communicatively coiq)led to the 
master control mechanism and being configured to, in response to one or 
more instructions fiom the master control medianism, establish a first 
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logical resource group tiiat contains a first subset of processing resources 
and a first subset of storage resources by: 

selecting the first subset of processing resources from a set of processing 
resources, 

selecting the first subset of storage resources from a set of storage 
resources, and 

causing the first subset of processing resources to be communicatively coupled to 
the first subset of storage resources. 
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